import { useUserStore } from "@/stores";
import { createRouter, createWebHistory } from "vue-router";
import NProgress from "nprogress";
import "nprogress/nprogress.css";

NProgress.configure({
  showSpinner: false,
});

const router = createRouter({
  history: createWebHistory(import.meta.env.BASE_URL),
  routes: [
    {
      path: "/login",
      component: () => import("@/views/Login/index.vue"),
      meta: {
        title: "登录",
      },
    },
    {
      path: "/",
      component: () => import("@/views/Layout/index.vue"),
      redirect: "/home",
      children: [
        {
          path: "home",
          component: () => import("@/views/Home/index.vue"),
          meta: {
            title: "首页",
          },
        },
        {
          path: "article",
          component: () => import("@/views/Article/index.vue"),
          meta: {
            title: "健康百科",
          },
        },
        {
          path: "notify",
          component: () => import("@/views/Notify/index.vue"),
          meta: {
            title: "消息通知",
          },
        },
        {
          path: "user",
          component: () => import("@/views/User/index.vue"),
          meta: {
            title: "个人中心",
          },
        },
      ],
    },
    {
      path: "/user/patient",
      component: () => import("@/views/User/PatientPage.vue"),
      meta: {
        title: "家庭档案",
      },
    },
    {
      path: "/consult/fast",
      component: () => import("@/views/Consult/ConsultFast.vue"),
      meta: {
        title: "急速问诊",
      },
    },
    {
      path: "/consult/dep",
      component: () => import("@/views/Consult/ConsultDep.vue"),
      meta: {
        title: "选择科室",
      },
    },
    {
      path: "/consult/illness",
      component: () => import("@/views/Consult/ConsultIllness.vue"),
      meta: {
        title: "病情描述",
      },
    },
    {
      path: "/consult/pay",
      component: () => import("@/views/Consult/ConsultPay.vue"),
      meta: {
        title: "问诊支付",
      },
    },
    {
      path: "/room",
      component: () => import("@/views/Room/index.vue"),
      meta: {
        title: "门诊室",
      },
      beforeEnter(to) {
        if (to.query.payResult === "false") return "/user/consult";
      },
    },
    {
      path: "/user/consult",
      component: () => import("@/views/User/ConsultPage.vue"),
      meta: {
        title: "问诊记录",
      },
    },
    {
      path: "/user/consult/:id",
      component: () => import("@/views/User/ConsultDetail.vue"),
      meta: {
        title: "问诊详情",
      },
    },
    {
      path: "/order/pay",
      component: () => import("@/views/Order/OrderPay.vue"),
      meta: {
        title: "药品支付",
      },
    },
    {
      path: "/order/pay/result",
      component: () => import("@/views/Order/OrderPayResult.vue"),
      meta: {
        title: "药品支付结果",
      },
    },
    {
      path: "/order/:id",
      component: () => import("@/views/Order/OrderDetail.vue"),
      meta: { title: "药品订单详情" },
    },
    {
      path: "/order/logistics/:id",
      component: () => import("@/views/Order/OrderLogistics.vue"),
      meta: { title: "物流详情" },
    },
  ],
});

// 前置路由守卫
router.beforeEach((to, from, next) => {
  NProgress.start();
  const store = useUserStore();
  // 白名单
  const whiteList = ["/login", "/register"];
  // 如果未登录且不在白名单内,前往登录
  if (!store.user?.token && !whiteList.includes(to.path)) {
    return next("/login");
  } else {
    return next();
  }
});

// 后置路由守卫
router.afterEach((to) => {
  NProgress.done();
  document.title = `医疗问诊-${to.meta.title || ""}`;
});

export default router;
